***8259 PROGRAMMABLE INTERRUP CONTROLLER***

**When we need multiple sources, we need to use an external device called as Priority Interrupt Controller (PIC). PIC helps to increase the Interrupt Handling Capacity of the Microprocessor. 8259A is the commonly used PIC which can easily help in handling Non-Vectored Interrupt of 8086-INTR.**

**FEATURES OF 8259**

1. **Programmable Interrupt used to work with 8086 and 8085.**
2. **Can Handle Edge as well as Level Triggered Interrupt**
3. **Flexible Priority Structure**
4. **Interrupts Can be Masked Individually**
5. **Vector Address of Interrupt is Programmable**
6. **Single 8259 can handle 8 Interrupts while cascaded configuration of 1 Master 8259. Similarly 8 Slave 8259 can handle 64 Interrupts**

**![C:\Users\this\Desktop\download.png](data:image/png;base64,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)**

|  |  |
| --- | --- |
| **BLOCK** | **INFORMATION** |
| **Data Bus Buffer** | * **Bi-Directional Buffer used to interface the internal data bus of 8259 with any external data bus.** * **Used to send read and control signals** * **Used to read interrupt type from the 8259** |
| **Read Write Logic** | * **Used to accept RD,WR,Ao,CS Signal** * **Used to control Data flow on Data Bus** * **Holds Initialization Command Words (ICWs) and Operational Commands Words(OCWs)** |
| **Comparator or Cascade Buffer** | * **Used in cascade mode operation** * **CAS2, CAS1, CAS0:  Output for Slave and Input for Master.**   **Using these 3 Lines there are 8 Possible Interrupts (23=8)**  **The Master Sends Address of the Slave on this lines**  **The Slaves read the address on these lines.**   * **SP/EN :   EN – Used to Enable the Buffer in Buffered Mode**   **SP – Functions as Output Line in Non Buffered Mode** |
| **Interrupt Request Register** | * **IRR – 8 Bit Register having 1-Bit for each interrupt lines IR7-IR0** * **Interrupt request occurs and the corresponding bit is set in the IRR** |
| **Interrupt Mask Register** | * **IMR- 8 Bit Register storing Masking Information of Interrupt IR7-IR0** * **This is written by the Programmer** |
| **In Service Register** | * **InSR - 8 Bit Register storing info about Interrupt Request being serviced** |
| **Priority Resolved** | * **Examines IRR,IMR,InSR and examines which interrupt has the highest priority of them all and send it to the micro-processer** |
| **Control Logic** | * **INT Output Signal connected to the INTR of Microprocessor** * **Also has the INTA input connected to the INTA of the Microprocessor** * **Also used to control the remaining blocks** |

**PIN CONFIGURATION of 8259**

|  |  |  |
| --- | --- | --- |
| **PIN** | **NUMBER** | **INFORMATION** |
| **Vcc** | **28** | **+5V Power Supply** |
| **GND** | **14** | **Ground** |
| **CS** | **1** | **Chip Select – Low on this pin enables RD and WR Communication** |
| **WR** | **2** | **Write – Low on this command enables to accept command words from CPU** |
| **RD** | **3** | **Read - Low on this command enables to release status onto data bus** |
| **D7-D0** | **4-11** | **Bidirectional Data Bud for data transfer** |
| **CASo-CAS2** | **12,13,15** | **Cascade Lines to control multiple 8259A structure** |
| **SP/EN** | **16** | **Slave Program or Enable Buffer**  **EN – Used to Enable the Buffer in Buffered Mode**  **SP – Functions as Output Line in Non Buffered Mode** |
| **INT** | **17** | **Interrupt Pin goes high when a valid interrupt request is asserted and is used to interrupt the CPU** |
| **IR0-IR7** | **18-25** | **Interrupt Request is asserted by pin going from low to high** |
| **INTA** | **26** | **Enable 8259 vector data into data bus by a Interrupt Acknowledgement** |
| **Ao** | **27** | **AO Address Line acts in conjunction of CS,WR,RD, and is used to decipher various command words** |

**END OF INTERRUPT**

**There are 3 different ways of sending END OF INTERRUPT command and they are as follows:**

|  |  |
| --- | --- |
| **Automatic EOI** | **No command needed here**  **In the 3rd INTA cycle corresponding bit in the InSR is reset** |
| **Non Specific EOI** | **Command is send to 8259 at the end of service routine**  **This would clear the bit of the currently serviced interrupt in InSR** |
| **Specific EOI** | **Command is send to 8259 at the end of service routine**  **This would clear the bit of the specified serviced interrupt in InSR** |

**OPERATION MODES**

**There are 2 different ways of Operating Modes of 8259 and they are as following**

|  |  |
| --- | --- |
| **Interrupt Driven** | **8259 interrupts processor with the INT Pin whenever it encounters a interrupt** |
| **Polled Mode** | **Here the INT mode is not used and checks the interrupt request by issuing the poll command. The micro-processor reads contents of 8259 and issues the poll command. During read operation provides polled words and sets the InSR bit of highest active interrupt** |

**PRIORITY MODES**

1. **Fully Nested Modes**
   1. **Default Mode of 8259**
   2. **Fixed Priority Mode**
   3. **IR0 – Highest and IR7 – Lowest**
2. **Special Fully Nested Modes**
   1. **Used for Master 8259 in cascading mode.**
   2. **The priority for the same are same as Fully Nested Modes**
   3. **Consider a large system that uses cascading 8259 where the interrupt level of each interrupt has to be considered. An interrupt input to the slave causes the slave to place an interrupt request to the master and on one of Master’s Input**
   4. **Interrupts to the same slave will not be recoganized and thus disabling further interrupts. This can be prevented using SFNM**
3. **Rotating Priority Mode**
   1. **Automatic Rotation Mode**
      1. **Preferred when multiple interrupts have the same priority**
      2. **After a device requests service, then it gets the lowest priority**
      3. **All other priorities rotates subsequently**
   2. **Specific Rotation Mode**
      1. **Here the user can fix the priorities**
4. **Special Mask Mode**
   1. **8259 disables interrupt requests lower or equal to the interrupt which is currently under service. SMM allows interrupts of all levels except one currently in service**
5. **Poll Mode**
   1. **Here INT line of 8259 is disabled**
   2. **Microprocessor gives Poll Command to 8259 using OCW3 and in return gets a Poll Word and then the service of interrupt takes place**
   3. **Helps when we need expand number of interrupts more than 64**
6. **Buffered Mode**
   1. **SP/EN becomes low during the INTA cycle and this is used to enable the buffer**